# 写在前面
body-parser是非常常用的一个express中间件,作用是对http请求体进行解析。使用非常简单,以下两行代码已经覆盖了大部分的使用场景。
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
@前端进阶之旅: 代码已经复制到剪贴板
本文从简单的例子出发,探究body-parser的内部实现。至于body-parser如何使用,感兴趣的同学可以参考官方文档。
# 入门基础
在正式讲解前,我们先来看一个POST请求的报文,如下所示。
POST /test HTTP/1.1
Host: 127.0.0.1:3000
Content-Type: text/plain; charset=utf8
Content-Encoding: gzip
chyingp
@前端进阶之旅: 代码已经复制到剪贴板
其中需要我们注意的有Content-Type、Content-Encoding以及报文主体:
- Content-Type:请求报文主体的类型、编码。常见的类型有
text/plain、application/json、application/x-www-form-urlencoded。常见的编码有utf8、gbk等。 - Content-Encoding:声明报文主体的压缩格式,常见的取值有
gzip、deflate、identity。 - 报文主体:这里是个普通的文本字符串
chyingp。
# body-parser主要做了什么
body-parser实现的要点如下:
- 处理不同类型的请求体:比如
text、json、urlencoded等,对应的报文主体的格式不同。 - 处理不同的编码:比如
utf8、gbk等。 - 处理不同的压缩类型:比如
gzip、deflare等。 - 其他边界、异常的处理。
# 一、处理不同类型请求体
为了方便读者测试,以下例子均包含服务端、客户端代码,完整代码可在笔者github上找到。
# 解析text/plain
客户端请求的代码如下,采用默认编码,不对请求体进行压缩。请求体类型为text/plain。
var http = require('http